





| L: ~ 20     | עכ |
|-------------|----|
| 2<br>2<br>3 |    |
| J V &       |    |
| у<br>Б<br>П |    |

| Fig. 30 | int b;          | <pre>funcB2(in1, a, *out1, *c, *d) {     b=a+b+in1;     c=a+1;     d=a+2;     out1=c+a; } funcB3(in2) {     b=in2+b; }</pre> | funcB5(in3, *a, c, d) {<br>a=in3+c+d;<br>b=c+d; |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| F18.3B  |                 | a:read<br>b:read, write<br>c:write<br>d:write<br>b:read, write                                                               | a:write<br>b:write                              |
| F 18.3A | int a, b, c, d; | <pre>funcB2(in1, *out1) {     b = a+b+in1;     c = a+1;     d = a+2;     out1 = c+a; } funcB3(in2) {     b = in2+b; }</pre>  | funcB5(in3) {     a = in3+c+d;     b = c+d      |

Fig. 4



Fig. 5





## Fig. 7

```
BUS bus 1 ("Bus1", arbitor_1, busread_1, buswrite_1);
Int arbitor_1(void);
RDATA busread_1(int add, int byte_count);
Int buswrite_1(int add, int data, int byte_count);
CPU ("cpu_1", &cpu_1_busif, 0, 0x10000, 0x00ffe000, 0x1000, 0x8000);
BusIntf cpu_1_busif("cpu 1 Bus I/F", &bus_1, 1)
SDRAM ExtSDRam1 ("External SDRam 1", EXTSDRAM1_START_ADD, EXTSDRAM1_SIZE)
c_cpuifB2 cpuifB2(); c_cpuifB4 cpuifB4(); c_cpuifB5 cpuifB5();
c_B2 funcB2(); c_B4 funcB4(); c_B5 funcB5();
SystemoneScep()
  funcB2. OneStep(); cpuifB2. OneStep();
  funcB4. OneStep(); cpuifB4. OneStep();
  funcB5. OneStep(); cpuifB5. OneStep();
Systeminit()
  funcB2. init(); cpuifB2. int();
  funcB4. init(); cpuifB4. int();
  funcB5. init(); cpuifB5. int();
SystemReset()
  funcB2. Reset(); cpuifB2. Reset();
  funcB4. Reset(); cpuifB4. Reset();
  funcB5. Reset(); cpuifB5. Reset();
```

## Fig. 8

```
RDATA busread_1 (int add, int byte_count)
  if ((add < start_bus_address) || (add > end_bus_address)) {
    return (NULL);
  }
  //RAM
  if ((add >= ExternalRAM. StartAddress) && (add < ExternalRAM. EndAddress))
    return ExternalRAM. Read (add - ExternalRAM. StartAddress, byte count);
  //ASIC
  if ((start_sub_address+B2_start_offset <= add)
       && (add < start_sub_address+B2_end_offset))
    cpuifB2. cpuread = 0;
    cpuifB2. bus addin = add;
    rd. Status = cpuifB2. Read10Reg();
    rd. data = cpuifB2. dataout;
  if ((start_sub_address+B4_start_offset <= add)
       && (add < start_sub address+B4_end_offset)) {
    cpuifB4. cpuread = 0;
    cpuifB4. bus_addin = add;
    rd Status = cpuifB4 ReadIOReg();
    rd.data = cpuifB4.dataout;
  if ((start_sub_address+B5_start_offset <= add)
       && (add < start_sub_address+B5_ens_offset))
    cpuifB5. cpuread = 0;
    cpuifB5. bus_addin = add;
    rd. Status = cpuifB5. Read10Reg();
    rd. data = cpuifB5. dataout;
  return (rd);
```

## Fig. 9

```
RDATA buswrite_1 (int add, int byte_count)
  if ((add < start_bus_address) || (add > end_bus_address)) {
    return(1);
  //RAM
  if ((add >= ExternalRAM. StartAddress) && (add < ExternalRAM. EndAddress))
    return ExternalRAM. Write (add - ExternalRAM. StartAddress, byte count);
  //ASIC
  if ((start_sub_address+B2_start_offset <= add)</pre>
       && (add < start_sub_address+B2_end_offset))
    cpuifB2. cpuwrite = 1;
    cpuifB2. bus_addin = add;
    cpuifB2. datain = data;
    rd. Status = cpuifB2. Write10Reg();
  if ((start_sub_address+B4_start_offset <= add)
       && (add < start_sub address+B4_end_offset))
    cpuifB4. cpuwrite = 1;
    cpuifB4. bus_addin = add;
    cpuifB4. datain = data;
    rd. Status = cpuifB4. WritelOReg();
  if ((start sub address+B5_start_offset <= add)</pre>
       && (add < start_sub_address+B5_ens_offset))
    cpuifB5. cpuwrite = 1;
    cpuifB5. bus addin = add;
    cpuifB5. datain = data;
    rd. Status = cpuifB5. WritelOReg();
  return (0);
```

Fig. 10



Fig. 11







Fig. 14

